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Response to Amendment 

This Office Action is in response to a communication received on September 27, 

2005. 

Claims 1, 8, 13, 19, 29, 36, 47, 56, 59, and 63 have been amended. 
Claims 1-63 are pending in this application. 

Claim Rejections - 35 USC § 103 

The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 1 02 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

Claims 1-63 are rejected under 35 U.S.C. 103(a) as being unpatentable over 
Leblang (5649200) in view of Schmidt (4558413) and in further view of Pickett 
(5649204). 

Regarding claim 1, Leblang teaches a computer-readable medium having 
computer-executable instructions comprising: querying a first server for the location 
information using the request, wherein the location information includes information 
about a location of a second server (Column 5, lines 45 - 53; Column 8, lines 31 - 35), 
that comprises the update information (Column 6, lines 4-19); linking the first server to 
the second server (Column 8, lines 31 - 35); querying the second server for the update 
information (Column 11, lines 53 - 64); receiving the update information from the 
second server (Column 9, lines 41 - 45; Column 12, lines 8-17), and updating 
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software based on the update information (Column 9, lines 41 - 45) and a unique 
defining a version file including a time stamp associated with the update information, the 
size of the update information, a signature associated with the update information, and 
the age of the update information (Column 31 , lines 30 - 37) . 

Leblang does not explicitly indicate assigning a value to a unique identifier that is 
used to identify a version of software associated with an executable, where in the value 
is associated with update information that is used to update the corresponding version 
of the software; generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier and that the unigue identifier includes the location of the update 
information, a method for locating the update information . 

Schmidt teaches a system for find software updates, which includes assigning a 
value to a unique identifier that is used to identify a version of software associated with 
an executable (Column 9, lines 43 - 47), where in the value is associated with update 
information that is used to update the corresponding version of the software (Column 9, 
lines 43 - 47); generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier (Column 9, lines 43 - 59) and that the unique identifier includes the 
location of the update information, a method for locating the update information (Column 
17, lines 57 - 60), a time stamp associated with the update information (Column 17. 
lines 65 - 67), a signature associated with the update information (Column 15, lines 28 
- 30), and the age of the update information (Column 1 7. lines 65 - 67) . 
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It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Schmidt's teachings of using unique identifiers to identify 
and locate software versions in a distributed system in Leblang's system in order to 
handle large programs and modules with multiple versions (Column 1 , lines 26 - 36). 

Leblang also does not explicitly indicate that the location information identifies a 
second server type, and that the location information identifies the protocol associated 
with the second server. Pickett teaches a system for finding information associated with 
a program using a first server to identify a second server location that contains the 
actual information (Column 1 , line 64 - Column 2, line 5). 

Picket teaches that the first server as part of transmitting the query from the client 
to the second server, uses protocol information found, and uses that protocol 
information to communicate with the second server in order to obtain the information 
(Column 3, lines 21 - 36). 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Pickett's teachings of having the redirecting server enabled 
to identify a second server type and use a different protocol based on the server type in 
order to allow the system perform in systems that include many different types of 
servers, while being transparent to the client (Column 3, lines 31 - 36). 

Regarding claim 2, Leblang teaches that querying a first server further 
comprises providing a path to a look up HyperText Transfer Protocol (HTTP) symbol 
location server (Column 8, lines 43 - 51 ). 
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Regarding claim 3, Leblang teaches that querying a first server further 
comprises querying a Dynamic Host Configuration Protocol (DHCP) server and 
requesting Uniform Resource Identifiers (URIs) to query the second server for the 
update information (Column 6, lines 1 - 19). 

Regarding claim 4, Leblang teaches that querying a first server further 
comprises querying a Domain Name System (DNS) server for a service (SRV) record 
identifying the second server to be queried (Column 8, lines 43 - 51 ). 

Regarding claim 5, Leblang teaches that querying a first server further 
comprises querying a directory service for the location of the second server (Column 6, 
lines 51 -61). 

Regarding claim 6, Leblang teaches that querying a first server further 
comprises querying an Application Configuration, Access Protocol (ACAP) server for 
the location of the second server (Column 12, lines 56-67). 

Regarding claim 7, Leblang teaches that querying a first server further 
comprises querying a Lightweight Directory Access Protocol (LDAP) server for the 
location of the second server (Column 8, lines 30 - 35; Column 1 1 , lines 61 - 64). 

Regarding claim 8, Leblang teaches a computer-readable medium having 
computer-executable instructions comprising: creating a path to a symbol location 
server (Column 14, lines 25 - 39); querying the symbol location server through the path 
for the symbols (Column 16, lines 31 - 44; lines 62 - 67); receiving the symbol from 
symbol location server through the path; and updating software associated with the 
local file using the symbol (Column 18, lines 25 - 32) and a unique defining a version 
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file including a time stamp associated with the update information, the size of the update 
information, a signature associated with the update information, and the age of the 
update information (Column 31 , lines 30 - 37) . 

Leblang does not explicitly indicate assigning a value to a unique identifier that is 
used to identify a version of software associated with an executable, where in the value 
is associated with update information that is used to update the corresponding version 
of the software; generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier that the unigue identifier includes the location of the update information, 
a method for locating the update information . 

Schmidt teaches a system for find software updates, which includes assigning a 
value to a unique identifier that is used to identify a version of software associated with 
an executable (Column 9, lines 43 - 47), where in the value is associated with update 
information that is used to update the corresponding version of the software (Column 9, 
lines 43 - 47); generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier (Column 9, lines 43 - 59) that the unigue identifier includes the location 
of the update information, a method for locating the update information (Column 17, 
lines 57 - 60), a time stamp associated with the update information (Column 17. lines 
65 - 67), a signature associated with the update information (Column 15, lines 28 - 30), 
and the age of the update information (Column 17, lines 65-67) . 



Application/Control Number: 09/670,073 Page 7 

Art Unit: 2155 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Schmidt's teachings of using unique identifiers to identify 
and locate software versions in a distributed system in Leblang's system in order to 
handle large programs and modules with multiple versions (Column 1, lines 26 - 36). 

Leblang also does not explicitly indicate that the location information identifies a 
second server type, and that the location information identifies the protocol associated 
with the second server. Pickett teaches a system for finding information associated with 
a program using a first server to identify a second server location that contains the 
actual information (Column 1, line 64 - Column 2, line 5). 

Picket teaches that the first server as part of transmitting the query from the client 
to the second server, uses protocol information found, and uses that protocol 
information to communicate with the second server in order to obtain the information 
(Column 3, lines 21 - 36). 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Pickett's teachings of having the redirecting server enabled 
to identify a second server type and use a different protocol based on the server type in 
order to allow the system perform in systems that include many different types of 
servers, while being transparent to the client (Column 3, lines 31 - 36). 

Regarding claim 9, Leblang teaches that assigning a value further comprises 
extracting the unique identifier from an image header of the local file (Column 15, lines 
47 - 51 ; Column 10, line 65 - Column 1 1 , line 3). 
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Regarding claim 10, Leblang teaches that a value is not replicated between 
differing versions of the local file (Column 9, lines 47 - 57). 

Regarding claim 11, Leblang teaches that receiving the symbol further 
comprises receiving a file comprising the symbol, wherein the file is stored in a local 
system memory (Column 1 3, line 65 - Column 14, line 7). 

Regarding claim 12, Leblang teaches that querying the symbol location server 
for further comprises querying the symbol location server with a user customized query 
which extracts over a back end store (Column 16, lines 40 - 44). 

Regarding claim 13, Leblang teaches a computer-readable medium having 
computer-executable instructions comprising: creating a path to the first server 
(Column 14, lines 25 - 39; Column 2, line 2); querying the first server through the path 
for the location information using the request (Column 2, lines 6-14); receiving the 
update information from the first server through the path; and updating software 
associated with the executable based on the update information (Column 2, lines 53 - 
64; Column 1 1 , lines 53 - 60) and a unique defining a version file including a time 
stamp associated with the update information, the size of the update information, a 
signature associated with the update information, and the age of the update information 
(Column 31, lines 30-37) . 

Leblang does not explicitly indicate assigning a value to a unique identifier that is 
used to identify a version of software associated with an executable, where in the value 
is associated with update information that is used to update the corresponding version 
of the software; generating a request to obtain location information of the update 
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information using the unique identifier; and that the software version is identified by the 
unique identifier that the unique identifier includes the location of the update information, 
a method for locating the update information . 

Schmidt teaches a system for find software updates, which includes assigning a 
value to a unique identifier that is used to identify a version of software associated with 
an executable (Column 9, lines 43 - 47), where in the value is associated with update 
information that is used to update the corresponding version of the software (Column 9, 
lines 43 - 47); generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier (Column 9, lines 43 - 59). It would have been obvious to one of 
ordinary skill in the art at the time the invention was made to use Schmidt's teachings of 
using unique identifiers to identify and locate software versions in a distributed system 
in Leblang's system in order to handle large programs and modules with multiple 
versions (Column 1 , lines 26 - 36) that the unique identifier includes the location of the 
update information, a method for locating the update information (Column 17, lines 57 - 
60), a time stamp associated with the update information (Column 17, lines 65 - 67), a 
signature associated with the update information (Column 15, lines 28 - 30), and the 
age of the update information (Column 17, lines 65 - 67) . 

Leblang also does not explicitly indicate that the location information identifies a 
second server type, and that the location information identifies the protocol associated 
with the second server. Pickett teaches a system for finding information associated with 
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a program using a first server to identify a second server location that contains the 
actual information (Column 1 , line 64 - Column 2, line 5). 

Picket teaches that the first server as part of transmitting the query from the client 
to the second server, uses protocol information found, and uses that protocol 
information to communicate with the second server in order to obtain the information 
(Column 3, lines 21 - 36). 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Pickett's teachings of having the redirecting server enabled 
to identify a second server type and use a different protocol based on the server type in 
order to allow the system perform in systems that include many different types of 
servers, while being transparent to the client (Column 3, lines 31 - 36). 

Regarding claim 14, Leblang teaches that receiving the update information 
further comprises receiving reference location associated the second server to access a 
file associated with the executable on the second server (Column 2, line 65 - Column 3, 
line 10). 

Regarding claim 15, Leblang teaches the idea of querying the second server 
further comprises querying a server selected from a group consisting of a DHCP server, 
a DNS server, an ACAP server, and a LDAP server (Column 3, lines 31 - 40; Column 2, 
line 65 - Column 3, line 1 ; Column 8, lines 43 - 51 ; Column 12, lines 56 - 67) where the 
type of connection and query and action the user takes, allows the system to take 
different action with the first server/ distributed system. 
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Regarding claim 16, Leblang teaches that querying the second server further 
comprises querying a set of servers in parallel (Column 16, lines 6-9) where the script 
allows the search of may objects/files at once and it also allows different types of 
searching for those files such as certain version location or query into the metadata. 

Regarding claim 17, Leblang teaches that querying the second server further 
comprises querying a set of servers in a serial order (Column 2, lines 65 - Column 3, 
line 4; Column 16, lines 62 - 67) because in order to connect all the objects and locate 
all related information to those objects the system needs to transverse all paths and 
types of location techniques in the system, such as first locating the object and the 
pathnames to that objects versions, then looking in the object directory for metadata 
leading to hyperlinks for other objects which are merged or related. 

Regarding claim 18, Leblang teaches that querying the second server further 
comprises packaging information extracted from the executable into a request and 
sending the request to first server (Column 9, lines 47 - 61). 

Regarding claim 19, Leblang teaches a computer-readable medium having 
computer-executable instructions comprising: querying a first server for the location 
information using the request, wherein the location information includes information 
about a location of a second server that comprises the update information (Column 2, 
lines 53 - Column 3, line 9); receiving the location information from the first server; 
creating a path to the second server based on the type of the update information 
(Column 2, lines 53 - Column 3, line 9; Column 16, lines 31 - 44); querying the second 
server through the path for the update information associated with the executable using 
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a syntax based on the location information received for the second server (Column 16, 
lines 40 - 44; Column 16, line 62 - Column 17, line 5); and updating software 
associated with the executable based on the update information (Column 2, lines 53 - 
64; Column 1 1 , lines 53 - 60) and a unique defining a version file including a time 
stamp associated with the update information, the size of the update information, a 
signature associated with the update information, and the age of the update information 
(Column 31, lines 30-37) . 

Leblang does not explicitly indicate assigning a value to a unique identifier that is 
used to identify a version of software assocated with an executable, where in the value 
is associated with update information that is used to update the corresponding version 
of the software; generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifie r that the unigue identifier includes the location of the update information, 
a method for locating the update information . 

Schmidt teaches a system for find software updates, which includes assigning a 
value to a unique identifier that is used to identify a version of software assocated with 
an executable (Column 9, lines 43 - 47), where in the value is associated with update 
information that is used to update the corresponding version of the software (Column 9, 
lines 43 - 47); generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier (Column 9, lines 43 - 59) that the unigue identifier includes the location 
of the update information, a method for locating the update information (Column 17, 
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lines 57 - 60), a time stamp associated with the update information (Column 17, lines 
65 - 67), a signature associated with the update information (Column 15, lines 28 - 30), 
and the age of the update information (Column 17. lines 65-67) . 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Schmidt's teachings of using unique identifiers to identify 
and locate software versions in a distributed system in Leblang's system in order to 
handle large programs and modules with multiple versions (Column 1 , lines 26 - 36). 

Leblang also does not explicitly indicate that the location information identifies a 
second server type, and that the location information identifies the protocol associated 
with the second server. Pickett teaches a system for finding information associated with 
a program using a first server to identify a second server location that contains the 
actual information (Column 1 , line 64 - Column 2 t line 5). 

Picket teaches that the first server as part of transmitting the query from the client 
to the second server, uses protocol information found, and uses that protocol 
information to communicate with the second server in order to obtain the information 
(Column 3, lines 21 - 36). 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Pickett's teachings of having the redirecting server enabled 
to identify a second server type and use a different protocol based on the server type in 
order to allow the system perform in systems that include many different types of 
servers, while being transparent to the client (Column 3, lines 31 - 36). 
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Regarding claim 20, Leblang teaches that querying a first server further 
comprises querying the first server using metadata associated with the executable 
(Column 15, lines 46-50). 

Regarding claim 21, Leblang teaches that querying the second server further 
comprises querying the second server using metadata associated with the executable 
(Column 16, lines 40 - 44; lines 63 - 67). 

Regarding claim 22, Leblang teaches that the metadata comprises metadata for 
a number of debug files (Column 17, lines 2-10). 

Regarding claim 23, Leblang teaches that the metadata comprises metadata for 
a number of source files (Column 2, lines 23 - 29). 

Regarding claim 24, Leblang teaches that querying the second server further 
comprises querying the second server for symbols associated with the executable 
(Column 2, lines 65 - Column 3, line 4). 

Regarding claim 25, Leblang teaches that querying the second server further 
comprises querying the second server for regression analysis data associated with the 
executable (Column 5, line 61 - Column 6, line 3). 

Regarding claim 26, Leblang teaches that querying the second server further 
comprises querying the second server for performance analysis data associated with 
the executable (Column 5, line 61 - Column 6, line 3). 

Regarding claim 27, Leblang teaches that querying the second server further 
comprises querying the second server for source code associated with the executable 
(Column 5, line 61 - Column 6, line 3). 
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Regarding claim 28, Leblang teaches that querying the second server further 
comprising receiving files comprising the update information associated with the 
executable file (Column 5, line 61 - Column 6, line 3). 

Regarding claim 29, Leblang teaches a computer-readable medium having 
computer-executable instructions for updating a software program associated with an 
executable file comprising: packaging metadata extracted from the executable file into 
an HTTP request (Column 2, lines 24 - 52); creating a path to a locator server (Column 
14, lines 25 - 39; Column 2, line 2), wherein the locator server comprises location 
information for a server on which the update information is located (Column 2, line 65 - 
Column 3, line 4); sending through the path the HTTP request to the locator servers; 
receiving the update information from the locator server through the path (Column 2, 
line 65 - Column 3, line 4); and updating the software program based on the update 
information (Column 2, lines 53 - 64; Column 1 1 , lines 53 - 60) and a unique defining a 
version file including a time stamp associated with the update information, the size of 
the update information, a signature associated with the update information, and the age 
of the update information (Column 31 , lines 30 - 37) . 

Leblang does not explicitly indicate assigning a value to a unique identifier that is 
used to identify a version of software associated with an executable, where in the value 
is associated with update information that is used to update the corresponding version 
of the software; generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
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unique identifier that the unique identifier includes the location of the update information, 
a method for locating the update information . 

Schmidt teaches a system for find software updates, which includes assigning a 
value to a unique identifier that is used to identify a version of software associated with 
an executable (Column 9, lines 43 - 47), where in the value is associated with update 
information that is used to update the corresponding version of the software (Column 9, 
lines 43 - 47); generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier (Column 9, lines 43 - 59) that the unique identifier includes the location 
of the update information, a method for locating the update information (Column 17, 
lines 57 - 60), a time stamp associated with the update information (Column 17, lines 
65 - 67), a signature associated with the update information (Column 15, lines 28 - 30), 
and the age of the update information (Column 1 7, lines 65 - 67) . 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Schmidt's teachings of using unique identifiers to identify 
and locate software versions in a distributed system in Leblang's system in order to 
handle large programs and modules with multiple versions (Column 1 , lines 26 - 36). 

Leblang also does not explicitly indicate that the location information identifies a 
second server type, and that the location information identifies the protocol associated 
with the second server. Pickett teaches a system for finding information associated with 
a program using a first server to identify a second server location that contains the 
actual information (Column 1 , line 64 - Column 2, line 5). 
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Picket teaches that the first server as part of transmitting the query from the client 
to the second server, uses protocol information found, and uses that protocol 
information to communicate with the second server in order to obtain the information 
(Column 3, lines 21 - 36). 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Pickett's teachings of having the redirecting server enabled 
to identify a second server type and use a different protocol based on the server type in 
order to allow the system perform in systems that include many different types of 
servers, while being transparent to the client (Column 3, lines 31 -36). 

Regarding claim 30, Leblang teaches that packaging metadata further 
comprising packaging metadata to locate an updated version of the executable file 
(Column 11, lines 53-64). 

Regarding claim 31, Leblang teaches that packaging metadata further 
comprises packaging metadata for locating a debug file associated with the executable 
file (Column 17, lines 2-10). 

Regarding claim 32, Leblang teaches that packaging metadata further 
comprises packaging metadata to locate a specific build version of the executable file 
(Column 9, lines 39-57). 

Regarding claim 33, Leblang teaches that receiving the update information 
further comprises receiving an HTTP redirect (Column 2, line 65 - Column 3, line 1). 

Regarding claim 34, Leblang teaches that receiving the update information 
further comprises receiving a location of the server on which the update information is 
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located, and querying the server with the unique identifier for the update information 
(Column 7, lines 54 - 61 ; Column 1 7, lines 22 - 29). 

Regarding claim 35, Leblang teaches that querying the server further comprises 
providing a qualifier (Column 15, lines 46 - 51). 

Regarding claim 36, Leblang teaches a computerized system, comprising: a 
first server comprising location information for update information associated with a 
local file (Column 2, lines 53 - 64; Column 11, lines 53 - 60); a second server 
comprising the update information, wherein the first server is linked to the second server 
though a path that is created based on the value (Column 2, line 65 - Column 3, line 4), 
and further wherein the first server receives the update information from the second 
server though the path (Column 15, line 56 - Column 16, line 9); and a computer 
comprising the local file, wherein the first server provides the update information to the 
computer such that software associated with the local file is updated based on the 
update information (Column 2, lines 53 - 64; Column 11, lines 53 - 60) and a unique 
defining a version file including a time stamp associated with the update information, the 
size of the update information, a signature associated with the update information, and 
the age of the update information (Column 31 , lines 30 - 37) . 

Leblang does not explicitly indicate assigning a value to a unique identifier that is 
used to identify a version of software associated with an executable, where in the value 
is associated with update information that is used to update the corresponding version 
of the software; generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
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unique identifier that the unique identifier includes the location of the update information, 
a method for locating the update information . 

Schmidt teaches a system for find software updates, which includes assigning a 
value to a unique identifier that is used to identify a version of software associated with 
an executable (Column 9, lines 43 - 47), where in the value is associated with update 
information that is used to update the corresponding version of the software (Column 9, 
lines 43 - 47); generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier (Column 9, lines 43 - 59). It would have been obvious to one of 
ordinary skill in the art at the time the invention was made to use Schmidt's teachings of 
using unique identifiers to identify and locate software versions in a distributed system 
in Leblang's system in order to handle large programs and modules with multiple 
versions (Column 1, lines 26 - 36) that the unique identifier includes the location of the 
update information, a method for locating the update information (Column 17, lines 57 - 
60), a time stamp associated with the update information (Column 17, lines 65 - 67), a 
signature associated with the update information (Column 15, lines 28 - 30), and the 
age of the update information (Column 17, lines 65 - 67) . 

Leblang also does not explicitly indicate that the location information identifies a 
second server type, and that the location information identifies the protocol associated 
with the second server. Pickett teaches a system for finding information associated with 
a program using a first server to identify a second server location that contains the 
actual information (Column 1, line 64 - Column 2, line 5). 
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Picket teaches that the first server as part of transmitting the query from the client 
to the second server, uses protocol information found, and uses that protocol 
information to communicate with the second server in order to obtain the information 
(Column 3, lines 21 - 36). 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Pickett's teachings of having the redirecting server enabled 
to identify a second server type and use a different protocol based on the server type in 
order to allow the system perform in systems that include many different types of 
servers, while being transparent to the client (Column 3, lines 31 - 36). 

Regarding claim 37, Leblang teaches that the update information comprises 
debug information (Column 17, lines 2-10). 

Regarding claim 38, Leblang teaches that the update information comprises 
solution access information (Column 5, line 61 - Column 6, line 5). 

Regarding claim 39, Leblang teaches that the computer reads the update 
information from the second server (Column 8, lines 31 - 35). 

Regarding claim 40, Leblang teaches that the first server comprises a 
HyperText Transfer Protocol (HTTP) server (Column 8, lines 43 - 51). 

Regarding claim 41, Leblang teaches that the HTTP server comprises a 
Dynamic Host Configuration Protocol (DHCP) server having Uniform Resource 
Identifiers (URIs) for querying the second server (Column 6, lines 1-19). 
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Regarding claim 42, Leblang teaches that the HTTP server comprises a 
Domain Name System (DNS) server having a service (SRV) record for identifying the 
second server (Column 8, lines 43 - 51). 

Regarding claim 43, Leblang teaches that the HTTP server comprises a 
directory service for providing the location information for the update information to the 
computer (Column 6, lines 51 -61). 

Regarding claim 44, Leblang disclose that the first server comprises an 
Application Configuration Access Protocol (ACAP) server (Column 12, lines 56 - 67). 

Regarding claim 45, Leblang teaches that the first server comprises a 
Lightweight Directory Access Protocol (LDAP) server (Column 8, lines 30 - 35; Column 
11, lines 61 -64). 

Regarding claim 46, Leblang does not explicitly indicate that the computer is 
networked to the first and the second servers over the Internet. 

Leblang teaches that the system is a distributed network, with servers and 
workstations (Column 6, lines 4-9) and that it uses pathnames to locate servers and 
information (Column 2, lines 65 - 66). 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to encourage the scalability of the system to enable it to run over a 
wider area network such as the Internet to allow a larger more geographically disperse 
development team to operate cooperatively in this system (Column 6, lines 10 - 26). 

Regarding claim 47, Leblang teaches a computerized system comprising: a first 
server comprising location information for update information associated with an 
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executable file (Column 5, lines 45 - 53; Column 8, lines 31 - 35; Column 2, lines 53 - 
64; Column 11, lines 53 - 60); a second server comprising the update information 
(Column 6, lines 4-10), wherein the first server is linked to the second server though a 
path that is created based on the value (Column 2, line 67 - Column 3, line 4); and a 
computer comprising the executable file, wherein the first server is adapted to provide 
the computer with the location information (Column 2, line 67 - Column 3, line 4), and 
further wherein the computer uses the location information to query the second server 
through the path for the update information (Column 8, lines 43 - 51 ) such that software 
is updated based on the update information (Column 2, lines 53 - 64; Column 11, lines 
53 - 60) and a unique defining a version file including a time stamp associated with the 
update information, the size of the update information, a signature associated with the 
update information, and the age of the update information (Column 31, lines 30-37) . 

Leblang does not explicitly indicate assigning a value to a unique identifier that is 
used to identify a version of software associated with an executable, where in the value 
is associated with update information that is used to update the corresponding version 
of the software; generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifie r that the unique identifier includes the location of the update information, 
a method for locating the update information . 

Schmidt teaches a system for find software updates, which includes assigning a 
value to a unique identifier that is used to identify a version of software associated with 
an executable (Column 9, lines 43 - 47), where in the value is associated with update 
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information that is used to update the corresponding version of the software (Column 9, 
lines 43 - 47); generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier (Column 9, lines 43 - 59) that the unique identifier includes the location 
of the update information, a method for locating the update information (Column 17, 
lines 57 - 60), a time stamp associated with the update information (Column 17, lines 
65 - 67), a signature associated with the update information (Column 15, lines 28 - 30), 
and the age of the update information (Column 1 7, lines 65 - 67) . 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Schmidt's teachings of using unique identifiers to identify 
and locate software versions in a distributed system in Leblang's system in order to 
handle large programs and modules with multiple versions (Column 1 , lines 26 - 36). 

Leblang also does not explicitly indicate that the location information identifies a 
second server type, and that the location information identifies the protocol associated 
with the second server. 

Pickett teaches a system for finding information associated with a program using 
a first server to identify a second server location that contains the actual information 
(Column 1, line 64 - Column 2, line 5). Picket teaches that the first server as part of 
transmitting the query from the client to the second server, uses protocol information 
found, and uses that protocol information to communicate with the second server in 
order to obtain the information (Column 3, lines 21 - 36). 
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It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Pickett's teachings of having the redirecting server enabled 
to identify a second server type and use a different protocol based on the server type in 
order to allow the system perform in systems that include many different types of 
servers, while being transparent to the client (Column 3, lines 31 - 36). 

Regarding claim 48, Leblang teaches the first server is selected from a group 
consisting of a DHCP server, a DNS server, an ACAP server, and a LDAP server 
(Column 3, lines 31 - 40; Column 2, line 65 - Column 3, line 1 ; Column 8, lines 43 - 51 ; 
Column 12, lines 56-67) where the type of connection and query and action the user 
takes, allows the system to take different action with the first server/ distributed system. 

Regarding claim 49, Leblang teaches that the computer is configured to query a 
hierarchy of first servers in a serial order (Column 2, lines 65 - Column 3, line 4; 
Column 16, lines 62-67) because in order to connect all the objects and locate all 
related information to those objects the system needs to transverse all paths and types 
of location techniques in the system, such as first locating the object and the pathnames 
to that objects versions, then looking in the object directory for metadata leading to 
hyperlinks for other objects which are merged or related. 

Regarding claim 50, Leblang teaches that the computer is configured to query a 
hierarchy of first servers in a parallel (Column 16, lines 6-9) where the script allows 
the search of may objects/files at once and it also allows different types of searching for 
those files such as certain version location or query into the metadata. 



Application/Control Number: 09/670,073 Page 25 

Art Unit: 2155 

Regarding claim 51, Leblang does not explicitly indicate that the update 
information comprises solution access information (Column 5, line 61 - Column 6, line 
5). 

Regarding claim 52, Leblang does not explicitly indicate that the computer is 
configured to query the second server, in an HTTP request format (Column 9, lines 47 - 
61), for the update information using a qualifier associated with the executable file 
(Column 15, lines 46 -51). 

Regarding claim 53, Leblang teaches that the query to the second server is 
performed using metadata extracted from the executable file (Column 2, lines 24 - 52). 

Regarding claim 54, Leblang teaches that the metadata extracted from the 
executable file comprising metadata for a debug file associated with the executable file 
(Column 17, lines 2- 10). 

Regarding claim 55, Leblang does not explicitly indicate that the metadata 
extracted from the executable file comprises metadata associated with regression 
analysis data for the executable file (Column 5, line 61 - Column 6, line 3). 

Regarding claim 56, Leblang teaches that a computer readable medium having 
computer executable instructions to cause a computing system to perform a method for 
updating software associated with an executable file (Column 5, lines 45 - 53; Column 
8, lines 31 - 35; Column 2, lines 53 - 64; Column 11, lines 53 - 60), comprising: 
creating a path for a lookup server to a server having update information based on the 
value (Column 14, lines 25 - 39; Column 2, line 2); using the lookup server to identify 
location information for the server having the update information based on metadata 
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extracted from the executable file; packaging an HTTP query for retrieving the update 
information through the path (Column 2, line 67 - Column 3, line 4; Column 8, lines 31 - 
35; Column 16, lines 31 - 44; lines 62 - 67); retrieving the update information; and 
updating the software associated with the executable file based on the update 
information (Column 2, lines 53 - 64; Column 1 1 , lines 53 - 60) and a unique defining a 
version file including a time stamp associated with the update information, the size of 
the update information, a signature associated with the update information, and the age 
of the update information (Column 31 , lines 30 - 37) . 

Leblang does not explicitly indicate assigning a value to a unique identifier that is 
used to identify a version of software associated with an executable, where in the value 
is associated with update information that is used to update the corresponding version 
of the software; generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier that the unigue identifier includes the location of the update information, 
a method for locating the update information . 

Schmidt teaches a system for find software updates, which includes assigning a 
value to a unique identifier that is used to identify a version of software associated with 
an executable (Column 9, lines 43 - 47), where in the value is associated with update 
information that is used to update the corresponding version of the software (Column 9, 
lines 43 - 47); generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier (Column 9, lines 43 - 59) that the unigue identifier includes the location 
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of the update information, a method for locating the update information (Column 17, 
lines 57 - 60), a time stamp associated with the update information (Column 17, lines 
65 - 67V a signature associated with the update information (Column 15, lines 28 - 30), 
and the age of the update information (Column 17, lines 65 - 67) . 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Schmidt's teachings of using unique identifiers to identify 
and locate software versions in a distributed system in Leblang's system in order to 
handle large programs and modules with multiple versions (Column 1, lines 26 - 36). 
Leblang also does not explicitly indicate that the location information identifies a second 
server type, and that the location information identifies the protocol associated with the 
second server. 

Pickett teaches a system for finding information associated with a program using 
a first server to identify a second server location that contains the actual information 
(Column 1, line 64 - Column 2, line 5). Picket teaches that the first server as part of 
transmitting the query from the client to the second server, uses protocol information 
found, and uses that protocol information to communicate with the second server in 
order to obtain the information (Column 3, lines 21 - 36). 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Pickett's teachings of having the redirecting server enabled 
to identify a second server type and use a different protocol based on the server type in 
order to allow the system perform in systems that include many different types of 
servers, while being transparent to the client (Column 3, lines 31 - 36). 
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Regarding claim 57, Leblang teaches that using the lookup server further 
comprises providing a response to a requesting client from the lookup server (Column 
1 6, lines 40 - 44; Column 1 7, lines 50 - 57). 

Regarding claim 58, Leblang teaches that providing a response further 
comprises forwarding the location information to the requesting client as an HTTP 
redirect (Column 8, lines 31 - 35). 

Regarding claim 59, Leblang teaches a method for updating software 
associated with a local file comprising: packaging metadata extracted from the local file 
into an HTTP request to obtain the update information (Column 2, lines 24 - 52); 
sending the HTTP request to a locator server; receiving location information back from 
the locator server (Column 8, lines 31 - 35; Column 16, lines 40 - 44; Column 17, lines 
50 - 57); packaging an HTTP query for retrieving the update information based on 
location information (Column 8, lines 43 - 51); and updating the software associated 
with the local file based on the information associated with the local file (Column 2, lines 
53 - 64; Column 11, lines 53 - 60) and a unique defining a version file including a time 
stamp associated with the update information, the size of the update information, a 
signature associated with the update information, and the age of the update information 
(Column 31. lines 30-37) . 

Leblang does not explicitly indicate assigning a value to a unique identifier that is 
used to identify a version of software associated with an executable, where in the value 
is associated with update information that is used to update the corresponding version 
of the software; generating a request to obtain location information of the update 
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information using the unique identifier; and that the software version is identified by the 
unique identifie r that the unique identifier includes the location of the update information, 
a method for locating the update information . 

Schmidt teaches a system for find software updates, which includes assigning a 
value to a unique identifier that is used to identify a version of software associated with 
an executable (Column 9, lines 43 - 47), where in the value is associated with update 
information that is used to update the corresponding version of the software (Column 9, 
lines 43 - 47); generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier (Column 9, lines 43 - 59) that the unique identifier includes the location 
of the update information, a method for locating the update information (Column 17, 
lines 57 - 60), a time stamp associated with the update information (Column 17, lines 
65 - 67), a signature associated with the update information (Column 15, lines 28 - 30). 
and the age of the update information (Column 17, lines 65 - 67) . 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Schmidt's teachings of using unique identifiers to identify 
and locate software versions in a distributed system in Leblang's system in order to 
handle large programs and modules with multiple versions (Column 1, lines 26 - 36). 
Leblang also does not explicitly indicate that the location information identifies a second 
server type, and that the location information identifies the protocol associated with the 
second server. 
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Pickett teaches a system for finding information associated with a program using 
a first server to identify a second server location that contains the actual information 
(Column 1, line 64 - Column 2, line 5). Picket teaches that the first server as part of 
transmitting the query from the client to the second server, uses protocol information 
found, and uses that protocol information to communicate with the second server in 
order to obtain the information (Column 3, lines 21 - 36). 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Pickett's teachings of having the redirecting server enabled 
to identify a second server type and use a different protocol based on the server type in 
order to allow the system perform in systems that include many different types of 
servers, while being transparent to the client (Column 3, lines 31 - 36). 

Regarding claim 60, Leblang does not explicitly indicate that packaging an 
query further comprises qualifying the query to select a specific file version from the 
update information (Column 8, lines 43 - 51 ). 

Regarding claim 61, Leblang does not explicitly indicate that qualifying the 
query further comprises qualifying the query to select an updated file version associated 
with the local file (Column 1 1 , lines 1 - 3) 

Regarding claim 62, Leblang does not explicitly indicate that qualifying the 
query further comprises qualifying the query to select a specific debug file associated 
with the local file (Column 17, lines 1 - 9). 

Regarding claim 63, Leblang teaches a server architecture, comprising; a first 
server; a second server linked to the first server based on a value (Column 5, lines 45 - 
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53; Column 8, lines 31 - 35; Column 2, lines 53 - 64; Column 1 1 , lines 53 - 60), 
wherein the second server comprises update information associated with the 
executable file (Column 6, lines 4-10); means for interpreting metadata associated 
with an executable file received by the first server from a remote client (Column 16, 
lines 40 - 44); means for redirecting the remote client to the second server wherein the 
second server is adapted to interpret a query from the remote client for retrieving the 
update information (Column 8, lines 31 - 35; lines 43 - 51 ); and means for updating 
software associated with the executable based on the update information (Column 2, 
lines 53 - 64; Column 1 1 , lines 53 - 60) and a unique defining a version file including a 
time stamp associated with the update information, the size of the update information, a 
signature associated with the update information, and the age of the update information 
(Column 31, lines 30-37) . 

Leblang does not explicitly indicate assigning a value to a unique identifier that is 
used to identify a version of software associated with an executable, where in the value 
is associated with update information that is used to update the corresponding version 
of the software; generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier that the unigue identifier includes the location of the update information, 
a method for locating the update information . 

Schmidt teaches a system for find software updates, which includes assigning a 
value to a unique identifier that is used to identify a version of software associated with 
an executable (Column 9, lines 43-47), where in the value is associated with update 
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information that is used to update the corresponding version of the software (Column 9, 
lines 43 - 47); generating a request to obtain location information of the update 
information using the unique identifier; and that the software version is identified by the 
unique identifier (Column 9, lines 43 - 59) that the unique identifier includes the location 
of the update information, a method for locating the update information (Column 17, 
lines 57 - 60), a time stamp associated with the update information (Column 17, lines 
65 - 67), a signature associated with the update information (Column 15, lines 28 - 30), 
and the age of the update information (Column 17, lines 65 - 67) . 

It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Schmidt's teachings of using unique identifiers to identify 
and locate software versions in a distributed system in Leblang's system in order to 
handle large programs and modules with multiple versions (Column 1 , lines 26 - 36). 
Leblang also does not explicitly indicate that the location information identifies a second 
server type, and that the location information identifies the protocol associated with the 
second server. 

Pickett teaches a system for finding information associated with a program using 
a first server to identify a second server location that contains the actual information 
(Column 1 , line 64 - Column 2, line 5). Picket teaches that the first server as part of 
transmitting the query from the client to the second server, uses protocol information 
found, and uses that protocol information to communicate with the second server in 
order to obtain the information (Column 3, lines 21 - 36). 
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It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to use Pickett's teachings of having the redirecting server enabled 
to identify a second server type and use a different protocol based on the server type in 
order to allow the system perform in systems that include many different types of 
servers, while being transparent to the client (Column 3, lines 31 - 36). 

Response to Arguments 

Applicant's arguments filed September 27 t 2005 have been fully considered but 
they are not persuasive. The applicant argues that the references do not disclose the 
amended limitations of having the unique identifier include, location information, a time 
stamp, the size of the update information, a signature associated with the update 
information, and the age of the update information. The examiner disagrees, as seen in 
the main reference, Leblang, the system has a method of identifying uniquely certain 
files in the system using a time stamp, file size information, and a signature (checksum) 
in Column 31 , lines 30 - 36 and the reference Picket teaches that unique files can be 
identified through their pathname, timestamp, a signature (48 bit hash) as seen in 
Column 17, lines 57-65, and age information is based on when the time stamp is 
created. It would be obvious when making the combination of references, to have a 
choice on which identifying information about software objects and update information 
to use to identify specific versions of those updated software objects. So the combined 
references render obvious the newly amended limitations. 

Conclusion 
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Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Kevin Bates whose telephone number is (571 ) 272- 
3980. The examiner can normally be reached on 8 am - 4:30 pm. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Saleh Najjar can be reached on (571 ) 272-4006. The fax phone number for 
the organization where this application or proceeding is assigned is 571-273-8300. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 
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